home *** CD-ROM | disk | FTP | other *** search
/ The Amiga Classic Collection / The Amiga Classic Collection - Disc 1.iso / Demo / DE146-MusicUtils.DMS / DE146-MusicUtils.adf / Miditt / midit.doc < prev   
Text File  |  1995-05-23  |  17KB  |  437 lines

  1. ****************************************************************
  2. *                                                              *
  3. *               MID-It! - MMDx to MID converter                *
  4. *                                                              *
  5. *               By Mario Bianchi - Version 1.2b                *
  6. *                      Date: 23 May 1995                       *
  7. *                                                              *
  8. ****************************************************************
  9.  
  10.  
  11.     INTRODUCTION
  12.     ------------
  13.  
  14. MID-It! is an OctaMED to MID music module converter.
  15.  
  16. It was made due to a personal need: I use OctaMED for making
  17. music at home, and sometimes I have to go to a music studio for
  18. giving my work a more professional touch.
  19.  
  20. Well, in short I was very tired of carrying my Amiga environment
  21. to the recording studios simply because the studio too had a
  22. computer (always Atari or Mac, sigh!!!), but it was never able
  23. to import OctaMED modules.
  24.  
  25. So I spent my spare time writing MID-It!.
  26. It allows you to load an OctaMED music module (MMD0 or MMD1) and
  27. get it converted in a few seconds to the universal MIDI file
  28. format 1!
  29.  
  30. I won't stay here naming all the software products that can deal
  31. with MIDI file format, just believe me when I say but they are
  32. really many, on any computer platform (never heard of Cubase,
  33. Notator, KCS Doctor T, and so on)?
  34.  
  35. I also know that the brand new version of OctaMED (V6) is
  36. capable of loading and saving MIDI files too, but can only
  37. output format 0 MIDI files, while MID-It! happily saves format 1
  38. files, though as yet it does not support MMD2 modules.
  39.  
  40.  
  41.     RESTRICTIONS AND REQUIREMENTS
  42.     -----------------------------
  43.  
  44. The current version has some limitations:
  45.  
  46.  - Modules must be MMD0 or MMD1 type; these two module formats
  47.    can be produced by all versions of OctaMED, and it seems to me
  48.    that MED newer versions, too, have the ability to save using
  49.    MMD0 format.
  50.    If you use OctaMED 5+, you can save your module using MMD0
  51.    or MMD1 format, but you must be sure that your module does
  52.    not use any of the extra features offered by MMD2 format
  53.    (refer to OctaMED documentation), otherwise your music could
  54.    loose some information if you save it using MMD0-1.
  55.  
  56.  - Modules must not contain any Amiga instruments (only MIDI
  57.    stuff is allowed!)
  58.  
  59.  - Modules must contain supplementary info - instrument names
  60.    and similar things, so be sure to save them using the right
  61.    save settings from MED/OctaMED before submitting your music
  62.    to MID-It!.
  63.  
  64.  - Only the first song of a multimodule will be converted.
  65.  
  66. MID-It! works with any kickstart version from 1.1 to 3.1
  67. - though I couldn't test it with all of them -
  68. but needs medplayer.library 2+ in your LIBS: drawer.
  69.  
  70. If you plan to convert MMD1 modules, version 3+ is needed.
  71.  
  72. Version 5 should be found on the Octamed developer's disk
  73. located on Aminet (file octamedv4_dev.lha in directory mus/edit,
  74. where you will also find a PD version of OctaMED.
  75.  
  76. Before using the library, though, read carefully the license and
  77. distribution files included!
  78.  
  79.  
  80.     USAGE
  81.     -----
  82.  
  83. MID-It! is only a CLI command, but it can be better handled by a
  84. good file manager like Directory Opus and Disk Master.
  85.  
  86. I'll add a small user interface if the program users - well
  87. enough of them :-) - ask me to.
  88.  
  89. Usage: midit <options> <input file> <output file>
  90.  
  91. If <output file> is not specified, it will be <input file>,
  92. modified as follows:
  93.  
  94.     - any leading "mod." or "med." is cut
  95.     - any trailing ".mod" or ".med" is cut
  96.     - extension ".MID" is appended to the filename
  97.  
  98. You can also specify only a path destination without filename,
  99. Valid examples:
  100.  
  101.     midit -b -r ram:module
  102.     midit -b -r -e -q ram:module ram:convmodule
  103.     midit -breq ram:module ram:convmodule    (same as previous)
  104.     midit -r ram:med.#? RAM:sound/
  105.  
  106. Please note the slash at the end of the last example: it must
  107. ALWAYS be present if you specify a destination subdirectory
  108. without destination filename, otherwise no output file will be
  109. produced.
  110.  
  111. AmigaDOS wildcards "#?" can be used in the input filename to
  112. convert several modules with a single command line, and a
  113. special option is present to activate Unix and MS-DOS "*?"
  114. wildcards, though excluding the AmigaDOS ones.
  115.  
  116. The output file is in all cases a MIDI file format 1, but its
  117. contents can be different, according to conversion type and
  118. option selected.
  119.  
  120.  
  121.     CONVERSION OPTIONS
  122.     ------------------
  123.  
  124. Three types of conversion can be performed, depending on the
  125. options specified.
  126.  
  127. Whatever conversion is used, the first track of the output MIDI
  128. file has the name of the song and contains only tempo changes,
  129. system exclusive messages, and various text events, if any.
  130.  
  131. The default conversion is the SMART one:
  132. it creates a file with one track for each instrument used in
  133. OctaMED plus a track (the first one), that has the name of the
  134. song.
  135. If you don't specify any conversion option, this is the one that
  136. will be performed.
  137.  
  138. The second conversion type is DIRECT (option -d):
  139. it builds a track for each OctaMED block track (this version
  140. supportes up to 16 tracks per block, but in future this number
  141. will surely grow up to 64).
  142.  
  143. This conversion generates a file in which every note is played
  144. following exactly the same order (note by note, command by
  145. command) as OctaMED does.
  146.  
  147. The third and last conversion is the CHANNEL one (option -c);
  148. it features one track for each MIDI channel; that is, if you use
  149. in a module more OctaMED instruments that share the same MIDI
  150. channel, they will be inserted in the same MIDI file track.
  151.  
  152. Smart conversion is better (I think is is more clever to have
  153. each instrument data in a separate track) but notes will be
  154. played in a different order than on OctaMED.
  155.  
  156. This, especially when you are working near the maximum
  157. poliphonic power of your MIDI machines, can make substantial
  158. differences when listening to the output MIDI file.
  159.  
  160. Of course, should this happen, you can change the arrangement of
  161. tracks to change note playing order.
  162. You should do it easily using a MIDI sequencer (my hint is: put
  163. first the rhythm instrument tracks).
  164.  
  165.  
  166.     MISC OPTIONS
  167.     ------------
  168.  
  169. Option -n can be used if you want that the MID file produced
  170. uses MIDI Note Off messages to turn off a note (OctaMED and
  171. Mid-It! default use instead Note On messages with 0 velocity).
  172.  
  173. Note Off messages have a fixed velocity of 127 (maximum value).
  174. If you use this option together with running status (see below)
  175. the file obtained will be longer than the 'only Note On' running
  176. status one.
  177. If you don't specify running status, file length is the same in
  178. either Note On or Off formats.
  179.  
  180. Option -p suppresses the conversion progress indicator.
  181.  
  182. Option -r produces a .MID file containing running status data,
  183. which is a simple method for compressing MIDI data.  A file
  184. using this feature is, in general, much shorter than the
  185. uncompressed one, but some sequencers (especially the very old
  186. ones) could get confused (just try it on your configuration).
  187.  
  188. Option -t causes the converter to shut all notes when the module
  189. ends (this way it can be played in loop without notes hanging
  190. across).
  191.  
  192. Option -b is valid for MMD1 modules only: this switch activates
  193. block name retain: block (or pattern, as you wish) name is
  194. introduced as a text event in the MID file just at the moment it
  195. starts to be played.
  196.  
  197. Option -e introduces an empty four beat bar before the real
  198. module data begin. This is useful if you want to insert your own
  199. MIDI setup messages before sound starts.
  200.  
  201. Option -u enables Unix/MS-DOS wildcards (*?) instead of the
  202. AmigaDOS ones.  This is for who is used to such systems or for
  203. converting a module which name contains the character # (the
  204. symbol ? is a wildcard anyway).
  205.  
  206. Option -q enables quiet mode, suppressing any warning that
  207. can be produced.
  208. BE CAREFUL: if you suppress warnings you make it at your own
  209. risk, because the conversion could be faulty and you could not
  210. be aware of it; you'd better be sure that your module is 'solid'
  211. before using this switch.
  212.  
  213.  
  214.     WATCH OUTS, WARNINGS AND HINTS
  215.     ------------------------------
  216.  
  217. I am putting all efforts to make the program bug free, but there
  218. are many features involved and particular conditions that can
  219. elude beta testing.  So you too can participate to make the
  220. project more and more solid and functional (and you are invited
  221. to do so).
  222.  
  223. MID-It is undergoing through continuous development.
  224. New features are implemented almost each day at this time,
  225. obeying at beta tester and user reports and ideas.
  226.  
  227. All the OctaMED commands and features that can be fit in a MIDI
  228. module are implemented, but not all situations could be actually
  229. tested (I am just a man...).
  230.  
  231. You will find below (in program history) the list of last things
  232. added, so be aware that these features are the less tested.
  233.  
  234. If you use Amiga samples instead (together with MIDI or alone)
  235. the module won't be converted - in current version at least.
  236.  
  237. There is a little workaround though: if you assign from OctaMED
  238. a MIDI channel to every non MIDI instrument (thus promoting it
  239. to MIDI), the module will be converted.
  240. Simply, don't expect a perfect conversion: notes will have to be
  241. transposed some octaves above and effects like pitchbend will
  242. sound awful if you try to play the module through a MIDI device.
  243. There is too much difference between Amiga and common MIDI sound
  244. hardware to map in a simple way sound handling from one to
  245. other.  At least, with little work, you can get a MIDI file
  246. containing all note events of your non MIDI instruments too. 
  247. This until a version fully supporting Amiga samples comes up, I
  248. don't know when and even if it will.
  249.  
  250. For BPM modules, one thing is worth of being explained.
  251. The slider at the right of the BPM one - I'm gonna call it
  252. "Resolution" from now on - is intended as a 'slots per beat'
  253. indication.
  254. That is, if you set resolution to 8, then 8 block lines are
  255. intended to form a metronome beat.  Keep it in mind if your
  256. converted file sounds at different speeds than the original,
  257. or if the sequencer metronome is not synchronized with song.
  258. By now, I still haven't found a way to infer the signature of an
  259. OctaMED song (how to understand that a song has a 12/8 tempo??),
  260. so that every MIDI file generated contains a 4/4 signature
  261. setting.
  262.  
  263. WARNING: if you use in your modules things such as pattern break
  264. or song position jump to leap back in the song, the converter
  265. will loop converting it forever!!!
  266. It is recommended that you prevent this nasty accident preparing
  267. your songs to be converted so that there is always an end.
  268.  
  269. ENFORCER HITS: if you have Enforcer active when converting
  270. you could notice some occasional hits.
  271. Deep investigations, together with OctaMED's author, Teijo
  272. Kinnunen, have found that medplayer.library prior to
  273. version 6 suffer from some bugs that can cause these hits,
  274. sometime even bringing to an incorrect conversion.
  275. The V6 library fixes this bugs successfully.
  276. You can check the source of the hits using segtracker
  277. together with Enforcer: if the hitting PC location is 
  278. reported in a medplayer.library hunk, this is one of the
  279. above mentioned situations. Otherwise please report them
  280. to me with as much detail as you can.
  281. I just can't do anything about it but advise you to get
  282. medplayer.library v6, as soon as the new OctaMED developer
  283. disk is out on the streets.
  284.  
  285. HINT: OctaMED 5+ has an hidden (undocumented on V5) command,
  286. 17xx, that writes directly byte xx into controller 7 (mostly
  287. used for MIDI volume control).  I don't know if older versions
  288. support it too, so, if you think that it could be useful for
  289. you, just try it!!!
  290.  
  291.  
  292.     DISTRIBUTION
  293.     ------------
  294.  
  295. This release of MID-It! is freely distributable, but only in the
  296. form of the full original archive (midit.lha).
  297. It is fully copyrighted by the author (Mario Bianchi) and you
  298. are not allowed to use it inside a commercial product nor sell
  299. it for profict without the written permission of the author.
  300. You can upload and spread the original archive wherever you
  301. wish, specifying that you are not the author.
  302.  
  303. I just ask for two more little things (don't flame me :->):
  304.  
  305.     1) If you use it frequently simply send me a postcard
  306.        from where you live, I'd really appreciate it!
  307.        This is not because I collect post cards, but instead
  308.        because I would like to know how many people are using
  309.        MID-It!, and what they think about it.
  310.  
  311.     2) I like feedback.
  312.        Please report me of every trouble, information, opinion
  313.        or enhancement you'd like to see or say about this
  314.        program.
  315.        I would also be glad if you could send me a short
  316.        description of your Amiga musical activities and
  317.        your usage - if any - of MID-It!
  318.  
  319.  
  320.     FUTURE PLANS
  321.     ------------
  322.  
  323. As you can see, there is still work to be done, but I am ready
  324. to do what I can to get it useful for as many people as I can.
  325. If people ask for a feature they'd like to find in a new
  326. release, then it is more likely that I implement it if I know
  327. that more people need it.
  328.  
  329. Just a few points that are floating in my mind:
  330.  
  331.     - Please don't ask to add complete Amiga samples support -
  332.       or ask it all together, so that I can't say no.
  333.  
  334.       Sure, it would be a great result, but I think I can't get
  335.       it all by myself in a short time (and I think it's better
  336.       that people reach the Amiga-MIDI world).
  337.       Besides that, consider that most internal audio commands,
  338.       like pitchbend, are really difficult to convert to MIDI,
  339.       because they depend on many factors outside the module
  340.       itself (MIDI device used, voice settings and so on).
  341.  
  342.     - One of the very next steps is let MID-It! support MMD2
  343.       module format too.
  344.  
  345.     - I wonder if multisong module support could be useful to
  346.       anyone...
  347.  
  348.     - Powerpacker, XPK and lha support (like OctaMED I hope).
  349.  
  350. I hope the development of this converter will closely follow
  351. OctaMED's enhancements - or maybe OctaMED itself will be
  352. enhanced in such a way to make MID-It! useless - who knows...
  353. But this is up to you too: the success and diffusion of a
  354. product depends very much on people supporting.
  355.  
  356.  
  357.     THANX TO...
  358.     -----------
  359.  
  360.     - Scott Watson, Michael Whitten and JF Giorgi for being
  361.       real friends and professional beta testers
  362.  
  363.     - Commodore for making Amiga
  364.  
  365.     - Teijo Kinnunen for writing OctaMED
  366.  
  367.     - The man who invented music
  368.  
  369.  
  370.     REACHING THE AUTHOR
  371.     -------------------
  372.  
  373.     You can contact me via email or normal mail.
  374.     Addresses are
  375.  
  376.     Mario Bianchi        email: biancm@ghost.sm.dsi.unimi.it
  377.     Via Bergamini 17
  378.     20122 Milano ITALY
  379.  
  380.     Email address is at University, so I can't guarantee ready
  381.     (daily) answering.
  382.  
  383.     Bye and *** SHARE AND ENJOY AMIGA AND MUSIC ***
  384.  
  385.  
  386.     PROGRAM HISTORY:
  387.  
  388.      4 March 1995 - project starts
  389.  
  390.      4 April 1995 - beta version 1.0 is ready.
  391.                     Only BPM, pure MIDI, no instrument data
  392.                     modules.
  393.                     I've already converted thirty modules,
  394.                     only getting polyphony problems with my
  395.                     MIDI keyboard.
  396.  
  397.      6 April 1995 - Real (mailed) beta testing begins.
  398.  
  399.     23 April 1995 - Version 1.0 does little, but does it
  400.                     well. Beta testers ask for MMD0 and
  401.                     ST + SPD timing compatibility.
  402.  
  403.     25 April 1995 - Version 1.1 is ready for second phase of
  404.                     beta testing.
  405.  
  406.        Changes:
  407.  
  408.        - Corrected bug when inserting program change in smart
  409.          mode - it was put in the track of the previous
  410.          instrument instead of the right one.
  411.  
  412.        - Added MMD0 comversion
  413.        - Added decimal volumes dealing
  414.        - Added ST and SPD compatibility
  415.        - Added Channel conversion type
  416.  
  417.     30 April 1995 - First release is ready (v1.1a)
  418.  
  419.     5 May 1995 - Awful bug discovered and hopefully fixed:
  420.                  various commands from FF1 to FFF caused also
  421.                  a tempo change! -> V1.1b
  422.  
  423.     7 May 1995 - Version 1.2b presents lots of new features:
  424.                  - Wildcard and filename extensions handling
  425.                  - Options -b, -e, -q, -u
  426.                  - A few (minor) bugs fixes
  427.                  - Annotation text saved as text event
  428.                  - Total playing time computed and inserted
  429.                    as text event
  430.                  - Enhanced option parser - can specify
  431.                    multiple options attached, like -qre
  432.                  - Due to wildcard support, inserted scan and
  433.                    conversion statistics
  434.  
  435.     23 May 1995 - No bug reports from beta testers -
  436.                   ready for Aminet upload!
  437.